package DescubrePeru.dao;

import java.sql.Connection;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException;

import DescubrePeru.excepcion.DAOExcepcion;
import DescubrePeru.modelo.Distrito;
import DescubrePeru.util.ConexionBD;

public class DistritoDAO extends BaseDAO{
	
	public void insertar(Distrito vo) throws DAOExcepcion {
		System.out.println("DistritoDAO: insertar(Distrito vo)");
		String query = "INSERT INTO DISTRITO(distrito_nombre)" +
				"VALUES (?)"; 
		
		Connection con = null;
		PreparedStatement stmt = null;
		try {
			con = ConexionBD.obtenerConexion();
			stmt = con.prepareStatement(query);
			
			stmt.setString(1, vo.getNombre());
						
			int i = stmt.executeUpdate();
			if (i != 1) {
				throw new SQLException("No se pudo insertar");
			}
		} catch (SQLException e) {
			System.err.println(e.getMessage());
			throw new DAOExcepcion(e.getMessage());
		} finally {
			this.cerrarStatement(stmt);
			this.cerrarConexion(con);
		}
		
	}
	
	public Distrito obtener(String idDistrito) throws DAOExcepcion {
		
		System.out.println("DistritoDAO: obtener(int IDDistrito)");
		Distrito vo = new Distrito();
		Connection con = null;
		PreparedStatement stmt = null;
		ResultSet rs = null;
		
		try {
			String query = "select idDISTRITO, distrito_nombre from DISTRITO where idDISTRITO=?";
			con = ConexionBD.obtenerConexion();
			stmt = con.prepareStatement(query);
			stmt.setString(1, idDistrito);
			rs = stmt.executeQuery();
			if (rs.next()) {
				vo.setIdDISTRITO(idDistrito);
				System.out.println("El ID del Distrito es: "+rs.getInt(1));
				System.out.println("El nombre del Distrito es: "+rs.getString(2));
			}
		} catch (SQLException e) {
			System.err.println(e.getMessage());
			throw new DAOExcepcion(e.getMessage());
		} finally {
			this.cerrarResultSet(rs);
			this.cerrarStatement(stmt);
			this.cerrarConexion(con);
		}
		return vo;
	}
	
	public void actualizar(int idDistrito, Distrito vo) throws DAOExcepcion {
		System.out.println("DistritoDAO: actualizar(Distrito vo)");
		String query = "update DISTRITO set distrito_nombre=? where idDISTRITO= "+ idDistrito;
		Connection con = null;
		PreparedStatement stmt = null;
		try {
			con = ConexionBD.obtenerConexion();
			stmt = con.prepareStatement(query);
			//stmt.setInt(1, idAdministrador);
			stmt.setString(1, vo.getNombre());
			int i = stmt.executeUpdate();
			if (i != 1) {
				throw new SQLException("No se pudo actualizar");
			}
		} catch (SQLException e) {
			System.err.println(e.getMessage());
			throw new DAOExcepcion(e.getMessage());
		} finally {
			this.cerrarStatement(stmt);
			this.cerrarConexion(con);
		}
	}

}
